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(54) TtUe: REDUCED COMPLEXITY BIT ALLOCATION TO SUBCHANNELS IN A MULTI-CARRIER, HIGH SPEED DATA 
TRANSMISSION SYSTEM 



(57) Abstract 

A communications Systran employing tiie Discrete Multitone (DMl^ line 
code divides the used frequency band W into a large number of subchannels, 
each with a bandwidth AfiAV/N, The signal in each subchannel is independently 
modulated at the symbol rate 1/A/. Because of noise and the non-ideal 
characteristics of the transmission channel, the signal-to-noise ratio (SNR) 
varies for different subchannels across tiie frequency band. Each subchannel 
is used to transmit an integer number of bits in a two-dimensional signal 
constellation, the susceptibility to noise increasing witfi ttie size of die 
constellation assuming that die same signal eneigy is used. In order to use 
the transmission channel optimally, subchannels are assigned difTerent numbos 
of bits depending cm their specific SNR values, i.e., a subchannel wift a high 
SNR value is assigned a large number of bits and vice versa. An c^timal bit 
allocation is determined diat ensures a certain bit error rate (BER) is obtained 
for all subchannels. In order to simplify numerical computations, thresholding 
is employed to make initial bit assignments. Further simplification of the bit 
loading procedures is obtained by ending bit allocation optimization efforts after 
a targeted BER is achieved. 
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REDUCED COMPLEXITY BIT ALLOCATION TO SUBCHANNELS IN A 
MULTLCARRIER, HIGH SPEED DATA TRANSMISSION SYSTEM 

FIELD OF THE INVENTION 

The present invention relates to multi-carrier, high speed data 
transmission and reception, and more particularly, to a method and system for simply 
and cost effectively allocating optimal bandwidth to each of the multi-carriers. 

BACKGROUND OF THE INVENTION 

The general principle of transmitting data by dividing it into several 
interleaved bit streams, and using these bit streams to modulate several carriers is well 
known. Modems using this principle employ what is referred to as Discrete Multitone 
(DMT) modulation and demodulation. These types of modems are being used or 
considered for use in such applications as cellular radio and High rate Digital 
Subscriber Lines (HDSL). 

In a Discrete Multitone system, the uiput bit stream is first serial-to- 
paiallel converted. The parallel output is then grouped into N groups of bits 
corresponding to the number of bits per symbol. Portions of bits are allocated to each 
DMT carrier or subchannel. The power transmitted over each subchannel corresponds 
to the number of bits transmitted over each DMT subchannel. 

Like a single carrier system, a multicarrier data transmission system tries 
to maximize a data transmission or bit rate for a particular Bit Error Rate (BER) and a 
particular Signal to Noise Ratio (SNR). In theory, the total bit rate (transmitted over all 
of the sub-channels) is maximized if the bit error rates for all the subchannels are equal. 
The concern is how best to allocate bits to each subchannel to attam the same BER over 
all of the subchannels. 
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Fig. 1 shows an example Discrete Multitone (DMT) communication 
system in which tiie present invention may be advantageously employed. Transmitter 
10 includes a s«ial-to-parallel converter 14, a multicanier modulator 16, and a 
pretransmit processor 1 8. Receiver 12 includes a post chaimel processor 20, a 
multicarrier demodulator 22, and a parallel-to-serial convoter 24. The transmitter and 
receiver are linked in this example by a digital subscriber line (DSL) or oth« form of 
communication channel 26. Serial input data at a rate of bfntal^ bits per second are 
grouped by converter 14 into blocks of btotal bits for each multicanier symbol, with a 
symbol period of T. The btotal bits in each multicarrier symbol are used to modulate N 
separate carriers in modulator 16 with bj bits modulating the i"tb carrier. 

A preferred example embodiment uses an Inverse Discrete Fourier 
Transform (IDFT) during modulation to generate Ng time-domain samples of a transmit 
signal for each block of btotal bits, where Ng is preferably equal to 2N. The 
corresponding multicarrier dranodulator performs a Discrete Fourier Transform (DFT), 
where bj bits are recovered fiiom the i"* carrier. As depicted in Fig. 2, the carriers or 
subchannels in a DMT system are spaced 1/T Hz apart across NfT Hz of the frequency 
band. More detailed discussion of the principles of multicarrier transmission and 
reception in general is given by J. A. C. Bingham in "Multicarrier Modulation for Data 
Transmission: An Idea Whose Time Has Come", IEEE Communications Magazine, 
Volume 28, Number 5, pp. 5-14, May 1990. 

The general structure of a Discrete Multitone Modulation DMT syston is 
illustrated in Fig. 3, where {Xo,Xi,..., Xn.i } are the original, complex, input data 
symbols, {x^} is the modulated data sequence (before cyclic prefix), {\} is the 
discrete-time chaimel response, {n^} is the additive noise sequence, {yj^} is the 
received sequence (after the removal of cyclic prefix), and { x q, x i, ...,3c n-1} are the 
decoded, complex data symbols. The pi's and pi*'s in Fig. 3 are known as the 
modulating and flie demodulating vectors, and preferably they are chosen to be 
orthonormal. 



« 
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Adding the cyclic prefix is a discrete-time technique used to eliminate 
interblock interference (IBI) in the DMT system. The independent modulating and 
demodulating vectors in Fig. 3 are the IDFT and the DPT vectors, given by the 
following pair of relationships: 

A DMT system with N complex subchannels in the frequency domain 
requires a DPT size of 2N, and the forced conjugate symmetry m the frequency domain 
results in the desired real-valued time domain samples. In the preferred embodiment, 
10 IDFT and DFT are implemented with the well known IFFT and FFT algorithms using 
the approach disclosed in commonly-assigned "Method and Apparatus for Efficient 
Computation of Discrete Fourier Transform and Inverse Discrete Fourier Transform," 
U.S. patent application Serial No. 08/887,467, (attorney docket 1410-340), filed on July 
2, 1997. 

15 Fig. 4 is a more detailed block diagram showing the principal operative 

components of a basic DMT transmitter 30 and a basic DMT receiver 32 connected 
through a chaimel 34. Serial input data are grouped mto blocks, converted to a parallel 
form, and appropriately encoded by an encoder 36. Each one of the N active 
subchannels contains a number of bk bits allocated to that subchannel. The total 

20 number of bits in a DMT symbol is therefore: 

^tola/^Z^* (3) 
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Each of the N bit groups is mapped by the symbol into a two-dimensional 
signal constellation. Hie relation between the number of bits in each block of bits bjk 
and the necessary number of signal points in a constellation M is given by: 

M, = 2*^ (4) 

The signal points in a constellation are typically arranged in a rectangular 
pattem for even values of and a cross for odd values of Provided that the same 
signal energy is used for all constellations, the distance between neighboring signal 
points is reduced with increasing constellation size resulting in increased BER with the 
same signal-to-noise ration (SNR). 

The output from the encoder is N complex numbers, one for each group of 
bits, which are then fed to a device that calculates the Inverse Discrete Fourier 
Transform (IDFT). The output is a real sequence that can be considered the 
superposing of N modulated orthogonal carriers spaced A/ apart. 

The parallel IFFT output is converted back to a serial data stream by a 
converter 40. The digital modulated data stream is cyclically prefixed, converted to 
analog form by a digital-to-analog converter (DAC) 42, low-pass filtered at 44, and 
passed through a D C. isolating transformer 46 during pre-transmit processing to 
produce an analog signal transmitted over a transmission channel 34. 

At the receiver end, the received analog signal is passed through a D.C. 
isolating transformer and low-pass filter 48, converted to digital form by an analog-to- 
digital converter (ADC) 50, time domain pre-equalized by a finite imptilse response 
(FIR) filter 52 to limit the effective memory of the channel, and stripped of the cyclic 
prefix during post-receive processing in converter 54. The resulting digital signals are 
demodulated by 2N FFT operation 56 and converted to parallel frequency domain 
signals. Since the amplitude vs. frequency and the delay vs. firequency responses of the 
channel are not necessarily constant across the entire used firequency band, the received 
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signal will differ from the transmitted signal, and tiie parallel inputs to the decoder 58 
will diflFer from those parallel outputs from the encoder 36. One form of equalization 
used to compensate these differences is a frequency domain equalizer (FEQ) which 
individually adjusts for the attenuation and delay of each of the carriers inunediately 
before the parallel frequency domain signals are passed to the decoder. The frequency 
domain equalized signals are appropriately decoded and converted back to a serial form 
by the decoder 58. Ideally, the detected output serial data from the decoder 58 is the 
same as the input serial data to the encoder 36. 

In a conventional single-carrier digital transmission system, such as a 
Quadrature Amplitude Modulation (QAM) system implemented with an equalizer or a 
encoder, the transmission bandwidth is determined by the symbol rate and the carrier 
frequency of the system. Unfortunately, variable symbol rate, single-carrier systems are 
still impractical to implement from a complexity standpoint with today's technology, 
and even if they are implemented, the granularity of possible symbol rates are typically 
very coarse. This is a direct consequence of the fact that for a fixed data rate, the 
symbol rate can only change in discrete multiples of bsynibol/{bsymbol^ U» where 
•^symbol is the nimiber of bits transmitted by each data symbol, provided that only 
signal constellations with integer numbers of bits are used. 

Multicarrier modulation, however, offers much more flexibility in 
granularity because it acts on block symbols that consist of a much larger number of 
bits per symbol over a large number of carriers. Since different numbers of bits can be 
transmitted throu^ die different carriers (subchannels), the multicarrier transceiver can 
control of the transmission bandwidth. As a result, more data bits are transmitted 
through the better carriers, i.e., having a greater Signal to Noise Ratio (SNR), and less 
data bits are transmitted througji the worse carriers, i.e., having a lower SNR as shown 
in Fig. 5. In this manner, optimal performance can be achieved, in terms of either 
maximizing total data throu^put for a fixed system performance margin or maximizing 
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overall system performance margin for a fixed target data rate under a fixed, total input 
power constraint and target bit-error-rate. 

Various bandwidtfa/bit allocation optimization techniques for multicarrier 
modulation have been proposed for different applications. The dieoretical optimal 
energy allocation is the well known water-pouring energy distribution as described for 
example in J.G. Proakis, (1995), Digital Communications S^d edition, McGraw-Hill, 
New York. Conceptually, the water pouring energy distribution model is obtained by 
first inverting the channel SNR cmve shown in Fig. 5 m the fi:€quency domain and then 
pouring the available energy into the resulting curve. The final "water level" at each 
particular fi-equency/carrier/subchannel is the optimal amount of energy to use at that 
particular firequency/carrier/subchannel. The number of bits transmitted by each carrier 
is determined by the maximum number of bits that can be supported by each carrier, 
given the water-pouring energy distribution and the desired bit-error-rate of each 
carrier. While the water-pouring technique yields the optimal bit and energy 
allocations, and therefore the optimal transmission bandwidth, it is typically complex 
and impractical to implement. 

Another niulticarrier bandwidth optimization technique designed for 
voice-band modem applications, where only constellations with an integer number of 
bits are used, was proposed by D, Hughes-Hartogs and described in "Ensemble Modem 
Structure for Imperfect Transmission Media", European Patent Number 0 224 556 Bl 
(published October 1991). The basic idea behind Hughes-Hartogs' algorithm is to 
incrementally add, one bit at a time, the amount of data to be transmitted in each 
multicarrier symbol until a desired data rate or power constramt is satisfied. 
Furthermore, this algorithm always chooses the subchannel that requires the least 
amount of incremental power to support an additional bit at the given desired bit-error- 
rate. Hughes Hartogs' algorithm, however, is typically too slow in convergence, 
making it especially unsuitable for applications where there are large numbers of 
carriers and bits to be supported by each multicarrier symbol as pointed out m P.S. 
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Chow, J.M. CiofiS, J.A.C. Bingham, "A Practical Discrete Multitone Transceiver 
Loading Algorithm for Data Transmission Over Spectrally Shaped Channels," IEEE 
Transactions on Communications, Vol. 43, No. 2/3/4, pp. 773 775, 1995. Also, the 
channel response is assumed to be fixed, i.e., time-invariant after training, which is not 
a good assumption for many applications, e.g., mobile radio conmiunications. 

In order to achieve faster convergence at the expense of a slight 
performance degradation. Chow et al. proposed a three-step bit loading algorithm. 
First, an optimal system performance margin is found; seqond, convergence is 
guaranteed with a suboptimal loop; and third, the energy distribution is adjusted for 
each subchannel if the transmission system is constrained by the total transmit power. 

However, Chow's bitloadmg algorithm requires computationally complex 
steps best run on a microprocessor and a number of iterative elements that may be 
excluded. Both requirements increase the system cost and reduce speed. The bit 
loading procedure in accordance with the present invention minhnizes computational 
complexity and permits execution by specific hardware which is faster than 
programmed microprocessor driver solutions. Also those parts of the algorithm that are 
best run on a microprocessor are of such basic character that only a rudimentary, 
inexpensive device is necessary. 

It is an object of this invention therefore to provide optimal bitloading 
using less computational power and at a fast rate. 

SUMMARY OF THE INVENTION 

Bits are allocated among subchannels in a multi-carrier modulation 
environment, under the constraint of a targeted bit error rate (BER) as well as a targeted 
number of bits per symbol. Thresholding is used to make initial bit assignments to 
subchannels in order to simplify numerical calculations. If the targeted BER cannot be 
achieved with the targeted number of bits, the overall channel is insufficient, and a 
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higher BER or a lower transmission rate must be considered. To further increase the 
efficiency of the process, a "block-reduction" step may be employed which reduces by 
one the number of bits allocated to each active subchannel if the total number of 
allocated bits exceeds the number of targeted bits by more than the number of active 
5 subchannels. Furtfa^ fine tuning may also be performed. 

The simplified bit allocation procedures in accordance with the present 
invention may be performed quite rapidly to permit adaptative allocation of bits in real 
time to accommodate, for example, changing channel conditions. In addition, the 
simplified procedures permit implementation using dedicated hardware for improved 
10 speed. 

More specifically, in a multi-carrier communications system with a 
transmitter and a receiver Imked together by a communications channel affected by 
noise and other channel impairments, data bits to be transmitted over the channel at a 
prescribed data transmission rate and bit error rate are allocated to plural subchannels. 

IS A series of thresholds is calculated for each subchannel with each threshold 

corresponding to a preset number of bits to be allocated to that subchannel. Each 
subchannel is associated with a signal constellation where bits allocated to the 
subchannel are mapped to signal points in the signal constellation. The subchannel 
thresholds are calculated based on the prescribed error rate, an average energy and size 

20 of the subchannel signal constellation. The threshold calculations need only be 
performed once, preferably before the transmitter/receiver is brought on-line. 

Subsequently, after the transceiver is brought into operation, an error 
estimate such as a noise standard deviation is obtained for each subchannel. That error 
estimate is compared to the thresholds calculated for the subchannel. The number of 
25 bits is then allocated to each subchannel corresponding to one of the thresholds 
exceeded by the obtained error measurement. The error estimate comparing and 
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obtaining procedures as well as the bit allocation may be performed in real time 
whenever the channel condition changes. 

A determination is made whether a total number of bits allocated to all the 
subchannels is greater than or equal to a total target number of bits associated with the 

5 prescribed data transmission rate. If not^ a decision is made whether to reduce the 
prescribed data transmission rate or to reduce the prescribed bit error rate. Otherwise, 
the number of bits allocated to one or more of the subchannels may be reduced until the 
total number of allocated bits is nearly equal to the total target number of bits. In 
particular, the number of bits to be allocated to each active subchannel may be reduced 

10 by one until the excess number of bits is less than the number of active subchannels. 

When a remainder of the excess number of bits is less than the number of 
active subchannels, ttie remainder may be further reduced by reducing the number of 
bits allocated to selected ones of the active subchannels. Bits are subtracted based on a 
magnitude of a difference between the error estimate and the exceeded threshold for 
15 each active subchannel. Those active subchannels having larger difference magnitudes 
are selected first for the bit reduction followed by subchannels having smaller 
difference magnitudes. 

BRIEF DESCRIPTION OF THE DRAWINGS 

Fig. 1 is a block diagram illustrating a basic prior art multicarrier 
20 transmitter, communication channel and receiver; 

Fig, 2 is a diagram conceptually illustrating fi-equency domain discrete 
multitone modulation (DMT); 

Fig. 3 is a diagram schematically depicting the basic structure of a 
discrete multitone modulation system; 
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Fig. 4 is a block diagram depicting the principal components of a discrete 
multitone (DMT) modulation commimication system; 

Fig. S illustrates DMT bit allocation in the fiequency domain; 

Fig. 6 illustrates two-dimensional 4 and 16 QAM signal constellations; 

Fig. 7 shows one example configuration implementing the thresholding 
operation and bit allocation procedures in accordance with one example embodiment of 
the present invention; 

Fig. 8 is a diagram providing a specific example threshold and bit 
allocation operation based on the example configuration shown in Fig. 7; 

Fig. 9 shows an alternative example configuration for implementing the 
thresholding and bit allocation operations in accordance with the present invention; and 

Fig. 10 illustrates bit loading procedures in flowchart form in accordance 
with the present invention. 

DETAILED DESCRIPTION OF THE INVENTION 

In tiie following description, for purposes of explanation and not 
limitation, specific details are set forth, such as particular hardware, applications, 
techniques, etc. in order to provide a thorough understanding of the present invention. 
However, it will be apparent to one skilled in the art that the present invention may be 
practiced in other embodiments that depart fi-om these specific details. In other 
instances, detailed descriptions of well known methods, protocols, devices, and circuits 
are omitted so as not to obscure the description of the present invention with 
unnecessary detail. 

The example apparatus that may be used in implementing the present 
invention may include the transmitter and receiver represented by the block diagram of 
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FIG. 4 already described above that in addition includes hardware and/or software for 
implementing the novel bit allocation procedures according to the present invention. 
The theoretical foundation for those bit allocation procediu^es now follows. 

Theoretical Foundation 

The bitloadtng procedures in accordance with the invention allocates bits 
to be transmitted in such a way that each subchannel satisfies the demands on 
probability of a symbol error, Pm, within a system performance margin. This bit 
allocation is based on a noise variance, , in each subchannel and prior knowledge of 
the average energy m each subchannel signal constellation, , which together 
effectively provide the signai-to-noise ratio SNR for each subchannel. Any additional 
safeguard margin of bits is distributed evenly among the subchannels. 

According to J.G. Proakis, (1995), Digital Communications S^d edition, 
McGraw-Hill, New Yoric, the symbol error probability P14 for a rectangular 
constellation in Additive White Gaussian Noise (AWGN) is tightly upper bounded by: 

where a number of constellation points M per subchannel is defined as 
M = 2^;b = 1,2,.... ,6^^ is the number of bits conveyed per each signal point in the 
constellation; is the average energy of the subchannel constellation and is a known 
design parameter set for each subchannel constellation; and is the single-sided 
power spectral density of the noise for a received signal constellation point (at the 
receiver) and is defined as = 2a^ , where is the received noise variance per 
real/imaginary dimension. The noise variance can be visualized (in a simplified 
manner) as the variance of the symbol error, i.e., between the signal point received and 
the closest constellation signal point in the complex plane. 
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The Q-function in equation (5) relates the signal-to-noise ratio (roughly 
defined ^ €^/Nf^)to the symbol error Pm for a particular constellation size and is 
defined mathematically as: 

Qix)= --^l^e^du (6) 

where u is the integral variable. In other words, the Q-fimction of a certain value x is 
calculated by solving the integral between the limits x and infinity. 

Even though P^i and BER are not identical, this analysis assumes that the 
symbol orror probability and bit error rate (BER) are approximately the same because 
one symbol usually corresponds to one or more bits. Certain symbol encoding 
techniques, (i.e., Gray coding where adjacent symbols containing the most likely errors 
only diflfer by one bit), may be employed to ensure that the bit error probability and the 
symbol error probability are very similar. 

In most pnictical applications, the bit error rate (and in this application the 
symbol error rate P^) is a known system design constraint. To achieve the same BER 
(or for all subchannel signal constellations and thereby opthnally allocate bits to 
each subchannel under a constraint that the average energy of all subchannel 
constellations is tfie same, the denominator of equation (5), (M-1) Nq must be 
maintained constant, i.e., 

(M-l)iVo=2a^(2*-l) = C (7) 

The constant C depends on the specific BER to be achieved and may be calculated 
according to: 



(8) 
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Solving equation (7) for the number of bits to be allocated, 6, provides the 
number of bits that may be assigned to a subchannel given a certain BER and the noise 
variance a] on that particular subchannel, i.e., the bit allocation for each subchannel k 
corresponding to : 




where is the noise variance per real (I) and imaginary (Q) dimension on 
subchannel A: In a preferred implementation, the bit loading values are limited to 
integCT constellations, e.g., by roundmg them to integer constellation sizes which affects 
the total number of allocated bits. 

In equation (7), both o and b may vary. The subchannel noise variance 
varies because of changing noise on the subchannel. Therefore, the number of bits 
bk allocated to that subchannel must be varied to compensate for the subchannel noise 
changes to ensure that equation (7) is satisfied as a constant and equal to C. If the 
subchannel noise variance increases, b^ must decrease, and fewer bits are sent over 
the subchannel. If decreases, b^ can be increased with more bits being sent. 

As already described, for a particular system design, the parameters Pm 
or BER, Q, and are preset/known. Therefore, only the noise variance cr^ needs to 
be determined for each subchannel to solve for the optimal bit allocation per subchannel 
according to equation (9). To obtain the subchannel noise variance , the noise 
standard deviation is determined based on a series of error measurements for 
symbols received on the subchannel. The subchannel noise standard deviation is the 
input to the bit loading procedures employed in the present invention and corresponds 
to the mean of the received symbol error magnitude (attributed to noise) for each 
subchannel. 
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The following described how the noise standard deviation estimate o-^ 



may be determined for each subchannel k. The received symbol error is the vector 
difference between a received signal point and the closest signal constellation point for 
a particular subchannel. Thus, the received symbol error is a complex number. To 
estimate the deviation of the error, either the real (I) or tiie imaginary (Q) part of the 
received symbol mot may be estimated for a theoretical ideal channel with truly 
Additive White Gaussian Noise (AWGN) because the I and Q components would have 
equal variance, i.e., the actually received signal points would be equally distributed in a 
circular pattem around the signal constellation point. In reality, the noise variance may 
be different in the I and Q dimensions, i.e., not a circular pattem, resultmg in poor noise 
deviation estimates if noise in only one of the two dimensions is measured. 



dimensions be estimated. The received symbol error magnitude can be e?q)ressed as: 



where Jf, and ^2 statistically-independent, gaussian-random variable 

each having a variance corresponding to the noise components in the complex I- and 
Q-dimensions. According to J.G. Proakis, (1995), Digital Communications S^d edition, 
McGraw-Hill, New York, the random variable R is Rayleigh distributed with an 
expected (E) mean value: 



From equation (11), the measured noise standard deviation estimate for each 
subchannel is preferably corrected using E(R), (i.e., by dividing the measured by 



Thus, it is preferred that the noise magnitudes in both the I and Q 




(10) 




(11) 




, in order to obtain the true value of a. 
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Example Embodiment of Subchannel Bit Allocation Procedures 

The subchannel bit allocation procedures in accordance with the present 
invention take as an input vector the corrected noise standard deviation estimate cr^ for 
each subchannel k. As described above, the main goal in optimally allocating bits is to 

5 maintain a constant, predetermined symbol error probability Pm/BER across each of the 
subchannels- Towards that goal, the invention uses thresholding to make initial bit 
assignments rather than using conventional complicated numerical computations. 
Furdier simplification is achieved by ending bit allocation optimization efforts after 9 
target Pm/BER is obtained. In another example embodiment, the preferred bit 

10 allocation procedures includes three basic steps that each converge within a finite 
amount of time. 

Thresholding 

A corrected, standard deviation of the noise for each subchannel k is 
estimated using a number of consecutively received symbols as described above in 

15 conjuntion with equations (10) and (1 1). A maximum number of bits to be allocated for 
each subchannel is then determined by comparing the estimated noise standard 
deviation measured for each subchannel A: to a series of thresholds r previously 
calculated and stored for each subchannel. Thus, rather than having to perform the 
complicated calculations in equations (8) and (9) including logarithms, exponentials, 

20 multiplications, etc., the present invention simply compares tiie estimated noise value 
measured for each subchannel to a number of thresholds. 

The thresholds themselves arc calculated only once, (e.g., off-line at a 
factory), and are subsequently used to establish a correspondence between a subchannel 
noise standard deviation value and a number of allocated bits b/^ for that subchannel. 
25 In other words, when the subchannel noise standard deviation value exceeds a certain 
limit, the number of bits that allocated to that subchannel changes. The subchannel 
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thresholds r are obtained by solving equation (7) for g and inserting equation (8) 
which yields: 




^9) = 1— ^7— r-^ (12) 



where q signifies the discrete values at which the subchannel signal constellation size 
changes. In effect, the subchannel constellation size changes with the measured 
subchannel noise to maintam a constant BER. The thresholds define the values of 
measured subchannel noise standard deviation a ^ where the constellation size changes 
as given by: 

1 3 1 

where is the maximum number of bits to be transmitted per subchannel, e.g., a 
maximum number of 12 bits. Once the thresholds are determined (preferably off-line) 
using equations (12) and (1 3) and the known values , and Pm and the function Q(x) 
for each subchannel, they are stored in memory along with a corresponding number of 
bits associated with each threshold. 

If the measured subchannel noise is so strong that not even the smallest 
constellation may be transmitted with the required bit error rate, that channel is not 
used, resulting in a zero bit allocation. Any subchannel with a bit allocation of zero 
reduces the number of active subchannels by one. 

The thresholding process is very simple compared to the complex 
calculations required by conventional bit loading algorithms. The thresholds are 
calculated following equations (12) and (13) and stored in niemory. The received 
symbol mean error magnitude is measured for each subchannel and used as an estimate 
of the subchannel noise standard deviation cr^ . The subchannel bit allocation h}^ is 



wo 99/16224 PCT/SE98/01598 

17 

associated to an interval betwera the two thresholds in which the value of the noise 
standard deviation estimate ctj^ fells. The thresholding/comparison may be 
implemented in software using a rudimentary data processor, or preferably in relatively 
simply hardware to increase operational speed. 

Fig. 7 is block diagram illustratmg the thresholding operation. TTie 
measured subchannel noise standard deviation cr^^ is input to a bank of parallel 
comparators 70. The other input of each comparator 70 is one of a mmiber of 
subchannel thresholds r calculated in accordance with equation (12) for different 
values of 9 as indicated in equation (13). In an example embodiment where 6,war is 12, 
there are twelve comparators 70 and twelve different stored threshold values r, - r,2 72. 
The combined outputs of each comparator 70 for a "bit vector" that is input to an 
encoder 74. The least significant bit (LSB) of the bit vector is fixed to zero. In each 
comparator 70, if the input noise deviation cr^ is less than the specific threshold value 
r , the comparator 70 generates a logical "1" at its output. Alternatively, if the input 
value is greater than the threshold, the comparator 70 generates a logical "0*' at its 
output. 

As illustrated in Fig. 8, the least significant bit in the comparator input bit 
vector supplied to the encoder 74 is in the zero position, and the encoder 74 outputs a 
zero if the bit vector contains only zeros. In effect, the specific comparator whose input 
threshold is first exceeded by the input noise standard deviation determines the 
number of bits indicated by encoder 74 to be allocated to that subchannel. In the case 
shown in Fig. 8, the smaller tiie noise standard deviation value, the larger the number of 
bits that may be allocated to the subchannel. 

Of course, the thresholding operation illustrated m Figs. 7 and 8 is only an 
example. Another example implementation is shown in Fig. 9 where a single 
comparison device 84 is used. The measured noise standard deviation for a 
subchannel is stored in an input register 80 and input to a comparator 84. Digital 
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threshold values r calculated for this subchannel are stored in threshold memory 82 
and are sequentially input to the digital comparator 84. The resulting sequential 
comparator outputs are passed tiirough a demultiplexer in order to write different 
positions in the bit vector register 88. The encoder 90 analyzes tiie bit vector stored in 
5 register 88, and ouQiuts the corresponding number of bits to be allocated for that 
subchannel based upon the thresholding comparison operation. 

If the total number of bits allocated to all subchannels in the thresholding 
step is less than the target number of bits, the desired bit rate cannot be achieved while 
maintaining the prescribed bit error rate because of increased noise or other factors. 

10 Consequently, the data transmission rate or the BER performance must be reduced. A 
decrease in transmission rate means allocating a fewer number of bits to each 
subchannel. Alternatively, another set of thresholds r corresponding to a higher BER 
may be employed. Thus, several sets of threshold values for different BERs may be 
calculated using equations (12) and (13) and stored m memory. However, the former 

15 decrease in transmission rate/allocated bits is preferred. 

Block Reduction 

If the total number of bits allocated across all subchannels exceeds the 
target number of bits, excess bits may be allocated to the active subchannels such that 
the data transmission rate can exceed the required data rate and still fulfill the 
20 prescribed bit error rate. If that goal is desired, tiie bit allocation procedures may end 
here. However, further bit allocation refmeraents may also be desirable. For example, 
the transmitted bit rate may be reduced to the prescribed bit rate to achieve certainty as 
well as an extra immunity to noise. 

If such further refinement is desired, a decision is made if the total 
25 number of allocated bits exceeds the target number of bits by more than the current 
number of active subchaimels, i.e., subchannels that have not been set to zero. If so, 
one bit is subtracted from the initially allocated number of bits to be transmitted on each 
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active subchannel. Of course, any subchannels that have zero bit allocations reduces 
the number of used subchannels by one. 

This ^'block reduction'' step is repeated until the number of allocated bits 
in excess of the overall target number of bits is less than the number of active 
subchaimels k. The reduced number of allocated bits corresponds to a lower overall 
transmission rate with the margin evenly distributed among the subchannels. 

Fine Correction 

A further fine correction step may be employed to compensate for the 
difference between the number of bits remaining to be allocated and the target number 
of bits after the block reduction step is completed. For each active subchannel, the 
relation between the estimated noise standard deviation and the threshold of its 
subchannel constellation is calculated as: 

= log,(a,y\og,(thr(b,)) (14) 

where //rr[6jt] signifies the operation of comparing the noise standard deviation of 
subchannel k to tiie precalculated thresholds for that subchannel. The distance df^ 
represents the difference between the noise standard deviation value cr^^ and the 
associated threshold r where the bitloading value changes. The subchannel having the 
largest distance is the first subchannel to have a bit removed fi-om the groups of 
allocated bits. 

Because bits are subtracted firom subchannels with the largest distance d^^ , 
the subchannel most sensitive to noise in its present constellation is advantageously 
reduced first. If the bit allocation of a subchannel that is not the most sensitive to noise 
is reduced, its immunity to noise is boosted. Unfortunately, the most sensitive 
subchaimel remains unchanged thereby becoming the "weakest link'\ The distance 



thr(h.\ 
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calculation ensures that the weakest links are the first to have bits removed then a 
relatively strong subchannel. 

This task may take more or less time consuming depending on the total 
number of subchannels to be reduced and on the choice of sorting algorithm. For 
example, assume there are 1024 subchannels and that after the block reduction step 
there are an excess of 1023 bits allocated, i.e., 1023 bits more than the targeted number. 
The task then is to reduce 1023 in order of 'iargest distance first" ' by finding the 1023 
largest elements in the distance vector.. If, on the odier hand, there is an excess of only 
10 bits, only the 10 largest elements in the distance vector need be found which takes 
less time. The sorting algorithm which sorts the distance vector elements from largest 
to smallest also afTects this process. A fast sorting algorithm may be more complex to 
implement, require a sophisticated nucroprocessor, etc. 

A flow chart diagram outlining example procedures for implementing the 
thresholding, block reduction, and fine correction steps is now described in conjunction 
with the bit allocation routine (block 100) illustrated in Fig. 10. An initial series of 
operations is performed usually at the time die device incorporatmg the present 
invention, such as a modem, is being manufiictured. More specifically, a series of 
threshold values r(g) is calculated for each subchannel in accordance with equations 12 
and 13 (block 102). In addition, each threshold value is correlated to a preset number of 
bits to be allocated for that subchannel. The threshold values and correlated numbers of 
bits are then stored. As mentioned above, different sets of threshold values 
corresponding to bit allocations may be calculated for several different bit/symbol error 
rates. The calculations and procedures performed in block 102 are generally performed 
only once. 

In terms of determining the actual number of bits to be allocated for each 
subchannel, the noise deviation estimate is measured for each subchannel and 
corrected in accordance with equation (11) (block 104). In a preferred embodiment, the 
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actual correction &ctor is incorporated in the one time threshold calculation process in 
block 102 since the correction &ctor is known. In addition, the number of active 
subchannels N^c is set to all of the subchannels (block 106). 

The noise standard deviation estimate for each subchannel erj^ is 
5 compared to the thresholds r predetermined for each subchannel from smallest to 
largest magnitude. When the noise standard deviation first exceeds one of the 
thresholds, the stored number of bits corresponding to that first exceeded threshold is 
allocated to that subchannel (block 108). For any subchannel where no bits can be 
allocated, the subchannel is deemed to be inactive, and the number of active 
10 subchannels iV^e is decremented. 

A decision is made whether the sum of the bits allocated to all of the 
subchannels is greater than or equal to a target number of bits Btarget (block 1 10), If 
not, the current channel conditions will not provide the targeted data bit rate at the 
targeted bit error rate. A decision must be made then to decide whether to change the 
15 bit error rate requirements or the bit transmission rate requirements (block 1 12). 
Depending upon whether such reduced service requirements are acceptable, control 
may return to block 1 02 or block 1 04. 

On the other hand, if the total number of bits allocated across all 
subchannels is greater than the target number of bits, another decision is made whether 

20 the number of bits that can be allocated to the subchannels in excess of the target 

number of bits exceeds or is equal to the number of active subchannels (block 1 14). If 
so, one bit may be subtracted from the nimiber of bits currently allocated to each active 
subchannel (block 1 16). Any subchannel whose group of allocated bits is reduced to 
zero after the subtraction operation causes a decrementing of the number of active 

25 subchannels N^c This is an iterative process with control returning to decision 
block 1 14 via the shown feedback path. 
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When the number of allocated bits in excess of the target number is less 
than the number of active subchannels Nsc> the distance for each subchannel k is 
determined in accordance with equation (14) (block 118). In order of decreasing 
distance values for each subchannel k, one bit is subtracted from each active subchannel 
until the sum of the allocated bits equals the target number of bits (block 120). 

While the present method may be performed under relatively static 
channel conditions, it may also be advantageously employed in dynamic channel 
conditions. For example, the noise on a particular subchannel may change over time. 
Accordingly, an inquiry is made in decision block 122 whether a subchannel condition 
has changed. If not, continued periodic inquiries may be made or the method may 
simply end. However, if the subchannel has changed, control returns to block 104 to 
obtain the updated noise deviation estimate for one or more subchannels affected by the 
condition change, and the method repeats. 

The present invention may, of course, be applied to any 
telecommunications application that employs multi-carrier type modulation, e.g., DMT, 
etc. Thus, while the invention has been describeid in connection witfi whiat is presently 
considered to be the most practical and preferred embodiment, it is to be understood 
that the invention is not to be limited to the disclosed embodiment, but on the contrary, 
is intended to Cover various modifications and equivalent arrangements included within 
the spirit and scope of the upended claims. 
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1 . In a multi-carrier conununications system with a transmitter and a 
receiver linked together by a communications channel affected by noise and other 
varying channel impairments where data bits to be transmitted over the channel at a 
prescribed data transmission rate and bit error rate are allocated to plural subchannels, a 
method comprising the steps of: 

calculating for each subchannel a series of thresholds corresponding to a preset 
number of bits to be allocated to the subchannel; 

obtaining an error estimate on each subchannel; 

comparing the error estimate for each subchannel to the thresholds calculated for 
the subchannel; and 

allocatmg a number of bits to each subchannel corresponding to one of the 
thresholds exceeded by the error estimate. 

2. The method in claim 1, wherein the calculating step is performed only 
once and the obtaining, comparing, and allocating steps are performed for an initial 
condition of the channel and again when the initial condition of the channel changes. 

3. The method in claim 2« further comprising: 

performing the obtaining, comparing, and allocating steps in real time whenever 
the channel condition changes. 

4. The method in claim 1, wherein the error estimate is a noise standard 
deviation measured for each subchannel. 

5. The method in claim 4, wherem the noise standard deviation is corrected 
for nonuniform characteristics. 

6. The method in claim 1, wherein each subchannel is associated with a 
signal constellation where bits allocated to the subchannel are mapped to signal points 
in the signal constellation, and wherein the subchannel thresholds are calculated based 
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on the prescribed bit error rate, an average energy of the subchannel signal 
constellation, and the signal constellation size. 

7. The method in claim 1, fiirlfaer comprising: 

determining whether a total number of bits allocated to all of the subchannels is 
greater than or equal to a total target number of bits associated with the prescribed data 
transmission rate. 

8. The method in claim 7, further comprising: 

if the total number of allocated bits is less than the total target number of bits, 
reducing the prescribed data transmission rate or reducing the prescribed bit error rate. 

9. The method in claim 7, further comprising: 

if the total number of allocated bits is greater than or equal to the total target 
number of bits, reducing the number of bits allocated to one or more of the subchannels 
until the total numba: of allocated bits is nearly equal to the total target number of bits. 

10. In a multi-carrier communications system with a transmitter and a 
receiver linked together by a communications channel afiTected by noise and other 
varying channel impairments where data bits to be transmitted over the channel at a 
prescribed data transmission rate and bit error rate are allocated to plural subchannels, a 
method comprising the steps of: 

obtaining an error estimate on each subchannel; 

comparing the error estimate for each subchannel to a series of thresholds 
corresponding to a preset nimiber of bits to be allocated to the subchannel; 

allocatmg a number of bits to each subchannel corresponding to one of the 
thresholds exceeded by the error estimate; and 

when a total number of bits allocated to all of the subchannels is in excess of a 
total target number of bits associated with the prescribed data transmission rate, 
reducing the number of bits to be allocated to each subchannel. 
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1 1 . The method in claim 1 0, further comprising: 

determining an active nmnber of subchannels having at least one allocated bit; 

and 

if the excess number of bits exceeds the active number of subchannels, reducing 
5 flie number of bits to be allocated to each active subchannel by one bit until the excess 
number of bits is less than the number of active subchannels. 

1 2. The method in claim 1 1 , further comprising: 

when a remainder of the excess number of bits is less than the number of active 
subchannels, fiirther reducing the reminder by reducing the number of bits allocated to a 
10 selected one of the active subchannels. 

13. The method in claim 12, wherein the one active subchannel is selected 
based on a magnitude of a difference between the error estimate and the exceeded 
threshold for each active subchannel, the active subchannel having the largest difference 
magnitude being selected as the one active subchannel. 

15 14. The method in claim 13, the further reducing step further comprising: 

subtracting one bit from each active subchannel in order of decreasing magnitude 
difference. 

15. The method in claim 10, repeating the steps in claim 10 when a condition 
of the channel changes. 

20 16. The method in claim 15, wherein the steps in claim 10 are repeated in real 

time. 

17. The method in claim 10, wherein the error estimate is a noise standard 
deviation measured for each subchannel. 
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1 8. The method in claim 17, wherein the noise standard deviation is corrected 
for nonuniform characteristics. 
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19. The method in claim 10, vdierein each subchamiel is associated with a 
signal constellation where bits allocated to the subchannel are encoded to signal points 
in the signal constellation, and wherein the subchannel thresholds are predetermined 
based on the prescribed bit error rate, an average energy of the subchannel signal 

s constellation, and the signal constellation size. 

20. A multi-carrier communications system comprising: 

a transmitter and a receiver linked together by a communications channel 
affected by noise and other varying channel impairments where data bits to be 
transmitted over the channel at a prescribed data transmission rate and bit error rate are 
10 allocated to plural subchannels; and 

electronic circuitry performing the following tasks: 

comparing the error estimate for each subchannel to a series of thresholds 
corresponding to a preset number of bits to be allocated to the subchannel, and 
allocating a number of bits to each subchannel corresponding to one of the 
15 thresholds exceeded by the error estimate. 

2 1 . The multi-carrier communication system according to claim 20, wherein 
the thresholds are calculated only once and the comparing and allocating tasks are 
performed when the channel condition changes. 

22. The multi*cairier communication system according to claim 20, wherein 
20 the error estimate is a noise standard deviation measured for each subchannel. 

23 . The multi-carrier communication system according to claim 22, wherein 
the noise standard deviation is corrected for nonuniform characteristics. 
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24. The multi-carrier communication system according to claim 20, wherein 
each subchannel is associated with a signal constellation where bits allocated to the 
subchannel are encoded to signal points m the signal constellation, and wherein the 
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subchannel thresholds are calculated based on the prescribed bit error rate, an average 
energy of the subchannel signal constellation, and the signal constellation size. 

25. The niulti-canier comniunication systeni accordmg to clabn 20, wher^^ 
the electronic circuitry determines whether a total number of bits allocated to all of the 

5 subchannels is greater than or equal to a total target number of bits associated with the 
prescribed data transmission rate. 

26. The multi-carrier communication system according to claim 25, wherein 
if the total number of allocated bits is less than the total target number of bits, the 
electronic circuitry reduces the prescribed data transmission rate or reduces the 

10 prescribed bit error rate. 

27. The multi-carrier communication system according to claim 25, wherein 
if the total number of allocated bits is greater than or equal to the total target number of 
bits, the electronic circuitry reduces the number of bits allocated to one or more of the 
subchannels until the total number of allocated bits is nearly equal to the total target 

15 number of bits. 

28. The multi-carrier communication system according to claim 27, where the 
electronic circuitry performs the following further tasks: 

determining an active number of subchannels having at least one allocated bit; 

and 

20 if the total number of allocated bits exceeds the total target number of bits by the 

active number of subchannels or more, reducing the number of bits to be allocated to 
each active subchannel by one bit until the excess number of bits is less than the number 
of active subchannels. 
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29. The multi-carrier communication system according to claim 28, wherein 
when a remainder of the excess number of bits is less than the number of active 



wo 99/16224 PCT/SE98/01598 

28 

subchannels, the electronic circuitry furtfier reducing the remainder by reducing the 
number of bits allocated to a selected one of the active subchannels. 

30. The multi-carrier communication system according to claim 29, wherein 
the one active subchannel is selected based on a magnitude of a difference between the 
error estimate and the exceeded threshold for each active subchannel, the active 
subchannel having the largest difference magnitude being selected as the one active 
subchannel. 

3 1 . The multi-carrier communication system according to claim 1 4, wherein 
the electronic circuitry subtracts one bit from each active subchannel in order of 
decreasing magnitude difference. 

32. The multi-carrier communication system according to claim 20, wherein 
the electronic circuitry implements the tasks using a programmed data processor. 

33. The multi-carrier conununication system according to claim 20, wherein 
the electronic circuitry implements the tasks using discrete hardware elements. 
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